Security News
RubyGems.org Adds New Maintainer Role
RubyGems.org has added a new "maintainer" role that allows for publishing new versions of gems. This new permission type is aimed at improving security for gem owners and the service overall.
get-it is a JavaScript HTTP client for making requests to APIs. It is designed to be modular and extensible, allowing developers to customize its behavior through plugins.
Basic GET Request
This feature allows you to make a basic GET request to a specified URL. The response is handled using Promises.
const getIt = require('get-it');
const request = getIt();
request({ url: 'https://api.example.com/data' })
.then(response => console.log(response))
.catch(error => console.error(error));
Using Plugins
get-it supports middleware plugins to extend its functionality. In this example, the jsonResponse plugin is used to automatically parse JSON responses.
const getIt = require('get-it');
const jsonResponse = require('get-it/lib/middleware/jsonResponse');
const request = getIt([jsonResponse()]);
request({ url: 'https://api.example.com/data' })
.then(response => console.log(response))
.catch(error => console.error(error));
Custom Headers
You can add custom headers to your requests. This is useful for adding authentication tokens or other custom headers required by the API.
const getIt = require('get-it');
const request = getIt();
request({
url: 'https://api.example.com/data',
headers: { 'Authorization': 'Bearer token' }
})
.then(response => console.log(response))
.catch(error => console.error(error));
Axios is a popular promise-based HTTP client for the browser and Node.js. It provides a simple API for making HTTP requests and supports interceptors, which are similar to get-it's plugins. Axios is widely used and has a large community.
node-fetch is a lightweight module that brings `window.fetch` to Node.js. It is a minimalistic library that focuses on providing a Fetch API in Node.js environments. Unlike get-it, it does not have built-in support for plugins or middleware.
Superagent is a small progressive client-side HTTP request library, and Node.js module with a lot of features. It supports a wide range of HTTP methods and has a plugin system similar to get-it. Superagent is known for its flexibility and ease of use.
Generic HTTP request library for node.js (>= 8) and browsers (IE9 and newer)
We wanted an HTTP request library that worked transparently in Node.js and browsers with a small browser bundle footprint.
To be able to use the same library in a range of different applications with varying requirements, but still keep the bundle size down, we took inspiration from http-client which cleverly composes functionality into the client.
Using a middleware approach, get-it
has the following feature set:
How get-it
behaves depends on which middleware you've loaded, but common to all approaches is the setup process.
// Require the core get-it package, which is used to generate a requester
const getIt = require('get-it')
// And require whatever middleware you want to use
const base = require('get-it/lib/middleware/base')
const jsonResponse = require('get-it/lib/middleware/jsonResponse')
const promise = require('get-it/lib/middleware/promise')
// Now compose the middleware you want to use
const request = getIt([base('https://api.your.service/v1'), jsonResponse()])
// You can also register middleware using `.use(middleware)`
request.use(promise())
// Now you're ready to use the requester:
request({url: '/projects'})
.then(response => console.log(response.body))
.catch(err => console.error(err))
In most larger projects, you'd probably make a httpClient.js
or similar, where you would instantiate the requester and export it for other modules to reuse.
url
- URL to the resource you want to reach.method
- HTTP method to use for request. Default: GET
, unless a body is provided, in which case the default is POST
.headers
- Object of HTTP headers to send. Note that cross-origin requests in IE9 will not be able to set these headers.body
- The request body. If the jsonRequest
middleware is used, it will serialize to a JSON string before sending. Otherwise, it tries to send whatever is passed to it using the underlying adapter. Supported types:
string
, ArrayBufferView
, Blob
, Document
, FormData
(deprecated: ArrayBuffer
)string
, buffer
, ReadStream
bodySize
- Size of body, in bytes. Only used in Node when passing a ReadStream
as body, in order for progress events to emit status on upload progress.timeout
- Timeout in millisecond for the request. Takes an object with connect
and socket
properties.maxRedirects
- Maximum number of redirects to follow before giving up. Note that this is only used in Node, as browsers have built-in redirect handling which cannot be adjusted. Default: 5
rawBody
- Set to true
to return the raw value of the response body, instead of a string. The type returned differs based on the underlying adapter:
ArrayBuffer
Buffer
By default, get-it
will return an object of single-channel event emitters. This is done in order to provide a low-level API surface that others can build upon, which is what the promise
and observable
middlewares do. Unless you really know what you're doing, you'll probably want to use those middlewares.
get-it
does not expose the low-level primitives such as the XMLHttpRequest
or http.IncomingMessage
instances. Instead, it provides a response object with the following properties:
{
// string (ArrayBuffer or Buffer if `rawBody` is set to `true`)
body: 'Response body'
url: 'http://foo.bar/baz',
method: 'GET',
statusCode: 200,
statusMessage: 'OK',
headers: {
'Date': 'Fri, 09 Dec 2016 14:55:32 GMT',
'Cache-Control': 'public, max-age=120'
}
}
For the most part, you simply have to register the middleware and you should be good to go. Sometimes you only need the response body, in which case you can set the onlyBody
option to true
. Otherwise the promise will be resolved with the response object mentioned earlier.
const getIt = require('get-it')
const promise = require('get-it/lib/middleware/promise')
const request = getIt([promise({onlyBody: true})])
request({url: 'http://foo.bar/api/projects'})
.then(projects => console.log(projects))
.catch(err => console.error(err))
If you are targetting older browsers that do not have a global Promise implementation, you must register one globally using a polyfill such as es6-promise:
require('es6-promise/auto')
const promise = require('get-it/lib/middleware/promise')
const request = getIt([promise()])
With the Promise API, you can cancel requests using a cancel token. This API is based on the Cancelable Promises proposal, which was at Stage 1 before it was withdrawn.
You can create a cancel token using the CancelToken.source
factory as shown below:
const promise = require('get-it/lib/middleware/promise')
const request = getIt([promise()])
const source = promise.CancelToken.source()
request
.get({
url: 'http://foo.bar/baz',
cancelToken: source.token
})
.catch(err => {
if (promise.isCancel(err)) {
console.log('Request canceled', err.message)
} else {
// handle error
}
})
// Cancel the request (the message parameter is optional)
source.cancel('Operation canceled by the user')
The observable API requires you to pass an Observable-implementation that you want to use. Optionally, you can register it under the global Observable
, but this is not recommended.
const getIt = require('get-it')
const observable = require('get-it/lib/middleware/observable')
const request = getIt()
request.use(
observable({
implementation: require('zen-observable')
})
)
const observer = request({url: 'http://foo.bar/baz'})
.filter(ev => ev.type === 'response')
.subscribe({
next: res => console.log(res.body),
error: err => console.error(err)
})
// If you want to cancel the request, simply unsubscribe:
observer.unsubscribe()
It's important to note that the observable middleware does not only emit response
objects, but also progress
events. You should always filter to specify what you're interested in receiving. Every emitted value has a type
property.
This module was inspired by the great work of others:
MIT-licensed. See LICENSE.
FAQs
Generic HTTP request library for node, browsers and workers
We found that get-it demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 56 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
RubyGems.org has added a new "maintainer" role that allows for publishing new versions of gems. This new permission type is aimed at improving security for gem owners and the service overall.
Security News
Node.js will be enforcing stricter semver-major PR policies a month before major releases to enhance stability and ensure reliable release candidates.
Security News
Research
Socket's threat research team has detected five malicious npm packages targeting Roblox developers, deploying malware to steal credentials and personal data.